Automatic view adjusting flight plan display

ABSTRACT

An FMS with the capability of automatically adjusting the view of the flight path as the flight progresses while maintaining a set viewing direction. The vertical dimension of the flight path display chosen to fill the display and provide increased readability.

CROSS REFERENCE TO RELATED APPLICATIONS

This application relates to allowed U.S. Pat. application Ser. No. 08/724,533, filed Sep. 30,1996, now allowed, entitled A FLIGHT MANAGEMENT SYSTEM WITH 3-DIMENSIONAL FLIGHT PATH DISPLAY, by James M. Suiter and Gary L. Owen, which is incorporated herein by this reference.

FIELD OF THE INVENTION

The present invention generally relates to flight management systems (FMSs) and more particularly to FMSs with vertical flight path displays and a novel 3-dimensional flight path display and even more particularly relates to automatically adjusting views for such flight plan displays.

BACKGROUND

In recent years, avionics engineers have endeavored to provide pilots and flight crews with the information necessary for safe flight. One approach has been to provide the flight crew with a constantly updated flight plan display as the flight progresses.

While this approach does have several beneficial aspects, it has several shortcomings. A purely mechanistic approach in which the display is constantly being totally rewritten can result in confusing or hard to read displays, especially during times of performing maneuvers which are dramatic with respect to the earlier segment of the flight.

Consequently, there exists a need for an improved system for displaying flight path information.

SUMMARY OF THE INVENTION

It is an object of the present invention to provide a enhanced FMS with reduced requirements of attention by the flight crew.

It is a feature of the present invention to include a 3-dimensional display of a flight path, which, during maneuvers, maintains a predetermined orientation of the view direction with respect to the flight plan.

It is an advantage of the present invention to reduce the requirement of a flight crew to mentally readjust to a new view angle orientation.

It is another feature of the present invention to include an automatic vertical scale adjustment.

It is another advantage of the present invention to provide enhanced readability of the vertical dimensions on a wide variety of flight plan segments.

The present invention is an FMS with enhanced abilities to calculate, display and advise the flight crew of flight path information which is designed to satisfy the aforementioned needs, provide the previously stated objects, include the above listed features, and achieve the already articulated advantages. In the present invention, the work load on a flight crew can be reduced and the situational awareness enhanced by providing a display of information which is easier to interpret.

Accordingly, the present invention is an FMS which includes a feature therein of generating a representation of a flight plan, having automatic view adjustments.

BRIEF DESCRIPTION OF THE DRAWINGS

The invention may be more fully understood by reading the following description of a preferred embodiment of the invention, in conjunction with the appended drawings wherein:

FIG. 1 a view of a typical 2-dimensional side representation of flight plan information of the prior art, which does not include an auto scaling function.

FIG. 2A is a view of a 2-dimensional side representation of flight plan information of the present invention which includes an autoscaling function, with a display ceiling of 6000 feet.

FIG. 2B is a view of a 2-dimensional side representation of flight plan information of the present invention which includes an autoscaling function, with a display ceiling of 10,000 feet.

FIG. 3 is 3-dimensional view of flight plan information in accordance with the present invention, with the aircraft at a first point and a set viewing direction.

FIG. 4 is another 3-dimensional view of the flight plan information of FIG. 3, but from a different position along the flight path while maintaining the same set viewing direction.

FIGS. 5 and 6 are block diagrams of flight management systems operable to embody the present invention.

DETAILED DESCRIPTION

Now referring to the drawings, where like numerals refer to like matter throughout, and more particularly to FIG. 1 there is shown a two dimensional plan view of a flight plan from Iowa City to Cedar Rapids, which is typical of prior art FMSs. The vertical dimension is shown at the same scale throughout the flight. Typically the flight plan data moves up and down, as the aircraft climbs or descends, but remains within plus or minus 20,000 feet of the actual aircraft altitude.

Now referring to FIG. 2A, there is shown a two dimensional side view, generally designated 200, of a flight plan from Iowa City to Cedar Rapids, of the present invention, which has an auto scaling feature with a vertical dimension which generally fills up the vertical area of the display. The scale 202 shown on the left side of the display shows a flight plan segment at 6000 feet. In general, the scale 202 can have variable ranges. E.g. for short distance flight plans the maximum altitude might be 5000 feet and while cruising a range of 40,000 feet might be used. Since the viewing area of the display is fixed, the ability to resolve the vertical nature of the flight plan details is increased when the scale 202 displays a lower ceiling. Optimally, the scale 202 is chosen to be as small as possible and still show the highest point of the flight plan within the horizontal range being displayed.

Now referring to FIG. 2B, there is shown a two dimensional side view, generally designated 201, of a flight plan this is similar to view 200 of FIG. 2A except that scale 203 has been changed to show an ascent to 10,000 feet to that the scale 203 shows a 10,000 feet ceiling in the same viewing area as a 6000 feet ceiling was shown in FIG. 2A.

Now referring to FIG. 3, there is shown three dimensional view, generally designated 300, from a viewing direction above, behind and to the left of the flight plan segment being currently flown by the aircraft. The aircraft is shown at point above the ground at 302. Point 302 is projected onto the ground at point 304. The aircraft is flying along flight segment 306. The view direction is at 75 degrees inclined from a straight down view, which would be a 0 degree vertical viewing direction. The 0 degree viewing direction will provide a 2-dimensional plan view, which might be called a "God's eye view." The lateral reference viewing direction is 345 degrees or 15 degrees west of north. Pointer 308 depicts a direction of 360 degrees or due north. As the aircraft continues along its flight plan and along segment 306 it will eventually reach the end of segment 306 and will need to make a turn to the left and proceed down along segment 310. When pilots make such maneuvers the orientation of the aircraft and the view displayed to the crew are rapidly changing. These rapid changes could, at times, be difficult to follow when viewed on a typical display. Consequently, it is desirable to provide a slow or intentionally retarded transition between such changes.

Now referring to FIG. 4, there is shown another three dimensional view, generally designated 400 of a later portion of the flight plan shown in FIG. 3 in which the aircraft has move along the flight path and is currently flying along segment 310. View 400 is drawn from a point in the same relative direction from the current flight plan segment as in FIG. 3. In other words the views in FIG. 3 and FIG. 4 might be referred to as "Guardian Angel views" in the sense that the views show what someone constantly remaining over the pilot's left shoulder would see. View 400 has changed to a lateral reference view of 292 degrees or 68 degrees west of north, while maintaining the same relative viewing angle with respect to the flight plan course. This constant relative viewing angle is believed to aid pilots and other flight crew members in rapidly adjusting to a new display after a relatively dramatic maneuver.

Referring now to FIG. 5, there is shown a block diagram of an exemplary flight management system (FMS) generally designated 500, operable to embody two-dimensional flight plan displays in accordance with the present invention, such as shown and described herein by way of reference to FIGS. 2A and 2B. Flight management system computer (FMSC) 502 performs lateral, vertical, and performance predicted flight plan computations in a well-known fashion. Coupled to FMSC 502, via digital data bus 503, is control display unit (CDU) 504, which performs the functions of input/output of flight plan text information. Lateral, vertical, and predicted flight path data used for text format is shared between CDU 504 and FMSC 502. A multifunction display (MFD) 506 is shown coupled via digital data bus 505, to and sharing lateral, vertical, and predicted flight path data used for graphical format with the FMSC 502. The MFD 506 is divided into a two-dimensional lateral map presentation segment 508 and a two-dimensional vertical map presentation segment 510. FMS 500 of FIG. 5 is very similar to incorporated FIG. 1A of U.S. application Ser. No. 08/724,533, except for software contained in a processor of the FMSC 502 or a processor in the display 506 for providing the auto scaling feature in accordance with the present invention.

Referring now to FIG. 6, there is shown a block diagram of an exemplary flight management system (FMS) generally designated 600, operable to embody three-dimensional flight plan displays in accordance with the present invention, such as shown and described herein by way of reference to FIGS. 3 and 4. Items numbered 502, 503, 504, and 505 of FIG. 5 also appear in FIG. 6. Also shown is a multifunction display 606 which is very similar to MFD 506, except for software contained therein for presentation and manipulation of three-dimensional views as shown in FIGS. 3 and 4 above. Display 606 may further contain an interface for coupling with view angle control 612 and aircraft altitude sensor and aircraft pitch/roll/heading sensor 614. Control 612 is preferably a joystick, mouse, or other similar well-known controller. Sensors 614 are well known in the art. FMS 600 of FIG. 6 is very similar to incorporated FIG. 1B of U.S. application Ser. No. 08/724,533, except for software contained in a processor of the FMSC 502 or a processor in the display 606 for providing a constant relative viewing angle feature in accordance with the present invention.

In operation, the FMS is operated in much the same manner and with the same hardware as prior art FMSs except that the flight plan information is updated as the flight progresses in a manner which reduces the need for pilots to become reaclimated to the view each time a course change occurs. The software disclosed in the appendix provides a detailed description of one embodiment of the present invention. The software is written in the ADA programming language which is well known in the art and which is capable of use with many computer processors which are well known in the art. The precise details of software code and hardware design are a matter of designer's choice and are believed to be readily understood and generated by persons skilled in the art.

Now referring to the appendix, there is disclosed a group of source code listings, in the ADA programming language which could be used by a processor in the display or FMSC. The partitioning of software and computational tasks between the numerous elements of system is a matter of individual designer's choice.

It is thought that the FMS, of the present invention, will be understood from the foregoing description and it will be apparent that various changes may be made in the form, construction, steps and the arrangement of the parts and steps, without departing from the spirit and scope of the invention or sacrificing all of their material advantages, the form herein being merely preferred or exemplary embodiments thereof.

APPENDIX

(Containing 10 Pages)

    __________________________________________________________________________     THIS PROCEDURE DECODES THE ALTITUDE WORD WITH ITS ASSOCIATED CONTROL           BITS.                                                                          |................................................................     ..........................................................................     .......................                                                        procedure Format.sub.-- Altitude                                                             (Word     : in ARINC.sub.-- 429.Message;                                       Bits      : in ARINC.sub.-- 429.BNR.sub.-- Bit.sub.--                                    Count;                                                               Start.sub.-- Index                                                                       : in Integer := 8;                                                   Chk.sub.-- Bits.sub.-- 9.sub.-- 10                                                       : in Boolean := false;                                               Alt.sub.-- Data                                                                          : in out                                                               Draw.sub.-- 3d.Altitude.sub.-- Data.sub.-- Record.sub.--                       Type;                                                                        Label     : in ARINC.sub.-- 429.Label.sub.-- Type := 0                                   ) is                                                   |                                                                     |       FUNCTIONAL DESCRIPTION - Reads a altitude from the input                       parameter and                                                 |        formats it at the specified location of the                  |        current display line and return decoded optional             |        altitude data if present.                                    |        3D addition.                                                 |                                                                     LIMITATIONS/NOTES - None.                                                      |................................................................     ..........................................................................     .......................                                                        Raw.sub.-- Alt                                                                         : System.sub.-- Types.Integer32;                                       Scaled.sub.-- Alt                                                                      : System.sub.-- Types.Float6;                                          Bit.sub.-- 9                                                                           : integer32;                                                           Bit.sub.-- 10                                                                          : integer32;                                                           Bit.sub.-- 11                                                                          : integer32;                                                           color.sub.-- msg                                                                       : String(1..3);                                                        type.sub.-- msg                                                                        : String(1..6);                                                        begin                                                                          Raw.sub.-- Alt := ARINC.sub.-- 429.Extract(Word, 12, ARINC.sub.--              429.Bit.sub.-- Count(Bits));                                                   Scaled.sub.-- Alt := Float6(Raw.sub.-- Alt);                                   Bit.sub.-- 9 := Integer32(ARINC.sub.-- 429.Extract(Word, 9, 1));               Bit.sub.-- 10 := Integer32(ARINC.sub.-- 429.Extract(Word, 10, 1));             Bit.sub.-- 11 := Integer32(ARINC.sub.-- 429.Extract(Word, 11, 1));             if ( not Chk.sub.-- Bits.sub.-- 9.sub.-- 10 ) then                             if Label = 8#006# then                                                         Alt.sub.-- Data.Elevation.sub.-- Alt := Units.Feet(Scaled.sub.-- Alt);         Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.-- 3d.Elevation;       else                                                                           Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.-- 3d.General;         Alt.sub.-- Data.General.sub.-- Alt := Units.Feet(Scaled.sub.-- Alt);           end if;                                                                        else                                                                           if  ( ( Bit.sub.-- 9 = 0 ) and ( Bit.sub.-- 10 = 0 ) ) then                    Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.-- 3d.Alt.sub.--       Computed;                                                                      Alt.sub.-- Data.Computed.sub.-- Alt := Units.Feet(Scaled.sub.-- Alt);          elsif ( ( Bit.sub.-- 9 = 0 ) and ( Bit.sub.-- 10 = 1 ) ) then                  if ( Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind = Draw.sub.-- 3d.Alt.sub.     -- At.sub.-- Or.sub.-- Above ) then                                                    Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.--                     3d.Above.sub.-- And.sub.-- Below;                                      else                                                                                   Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.--                     3d.Alt.sub.-- At.sub.-- Or.sub.-- Below;                               end if;                                                                        Alt.sub.-- Data.At.sub.-- Or.sub.-- Below.sub.-- Alt := Units.Feet(Scaled.     sub.-- Alt);                                                                   elsif ( ( Bit.sub.-- 9 = 1 ) and ( Bit.sub.-- 10 = 0 ) ) then                  if ( Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind = Draw.sub.-- 3d.Alt.sub.     -- At.sub.-- Or.sub.-- Below ) then                                                    Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.--                     3d.Above.sub.-- And.sub.-- Below;                                      else                                                                                   Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.--                     3d.Alt.sub.-- At.sub.-- Or.sub.-- Above;                               end if;                                                                        Alt.sub.-- Data.At.sub.-- Or.sub.-- Above.sub.-- Alt := Units.Feet(Scaled.     sub.-- Alt);                                                                   else                                                                           Alt.sub.-- Data.Alt.sub.-- Spec.sub.-- Kind := Draw.sub.-- 3d.Draw.sub.--      Symbol.sub.-- At.sub.-- Alt;                                                   Alt.sub.-- Data.Draw.sub.-- At.sub.-- Alt := Units.Feet(Scaled.sub.--          Alt);                                                                          end if;                                                                        end if;                                                                        if ( Bit.sub.-- 11 = 0 ) then                                                  Alt.sub.-- Data.Altitude.sub.-- Symbol.sub.-- Color := Draw.sub.--             3d.Green;                                                                      else                                                                           Alt.sub.-- Data.Altitude.sub.-- Symbol.sub.-- Color := Draw.sub.--             3d.Yellow;                                                                     end if;                                                                        Map.sub.-- Display.sub.-- Buffer(Dsp.sub.-- Index)(Start.sub.-- Index) :=      `A`;                                                                           INT.sub.-- IO.Put(To  =>                                                       Map.sub.-- Display.sub.-- Buffer(Dsp.sub.-- Index)(Start.sub.-- Index+1..S     tart.sub.-- Index + 5),                                                        Item => Integer32(Scaled.sub.-- alt));                                         if chk.sub.-- bits.sub.-- 9.sub.-- 10 then                                     If  ( Bit.sub.-- 9 = 0 ) and ( Bit.sub.-- 10 = 0 ) then                                type.sub.-- msg := "COMPUT";                                           elsif ( Bit.sub.-- 9 = 0 ) and ( Bit.sub.-- 10 = 1 ) then                              type.sub.-- msg := "BELOW";                                            elsif ( Bit.sub.-- 9 = 1 ) and ( Bit.sub.-- 10 = 0 ) then                              type.sub.-- msg := "ABOVE";                                            else                                                                                   type.sub.-- msg := "DRAWAT";                                           end if;                                                                        Map.sub.-- Display.sub.-- Buffer(Dsp.sub.-- Index)(Start.sub.-- Index+7..S     tart.sub.-- Index+12) := type.sub.-- msg;                                      if ( Bit.sub.-- 11 = 0 ) then                                                          color.sub.-- msg := "GRE";                                             else                                                                                   color.sub.-- msg := "YEL";                                             end if;                                                                        Map.sub.-- Display.sub.-- Buffer(Dsp.sub.-- Index)(Start.sub.-- Index+14..     Start.sub.-- Index+16) := color.sub.-- msg;                                    end if;                                                                        end Format.sub.-- Altitude;                                                    THESE CODE SEGMENTS SHOW 1) HOW THE ELEVATION DATA RECIEVED IS USED            TO ADJUST ALTITUDES ABOVE THE GRID, AND THUS THE GRID ELEVATION;               2) CALULATION OF THE AUTO-SCALING FACTOR, CUR.sub.-- VERT.sub.-- SCALE.sub     .-- 3D, IS SHOWN;                                                              AND 3) THE 5000 FOOT MINIMUM VERTICAL SCALE (MIN.sub.-- ALT.sub.--             FOR.sub.-- SCALING.sub.-- 3D)                                                  WHEN RECIEVED ELEVATION OF A ARRIVAL OR DEPARTURE AIRPORT                      THAT IS ON THE CLIPPED MAP                                                     when Elevation =>                                                              Have.sub.-- Elevation := True;                                                 Current.sub.-- Elevation.sub.-- 3d := Float(Alt.sub.-- Data.Elevation.sub.     -- Alt);                                                                       Elevation.sub.-- Alt.sub.-- Valid.sub.-- 3d := True;                           if ( Current.sub.-- Elevation.sub.-- 3d < Min.sub.-- Elev.sub.-- 3d)           then                                                                           Min.sub.-- Elev.sub.-- 3d := Current.sub.-- Elevation.sub.-- 3d;               end if;                                                                        .                                                                              .                                                                              .                                                                              Current.sub.-- Adj.sub.-- Altitude.sub.-- 3d := Current.sub.-- Altitude.su     b.-- 3d - elevation.sub.-- trans;                                              if  ( Current.sub.-- Adj.sub.-- Altitude.sub.-- 3d > Adj.sub.-- Max.sub.--          Alt.sub.-- 3d ) and                                                           ( Current.sub.-- Adj.sub.-- Altitude.sub.-- 3d > Min.sub.-- Alt.sub.--          For.sub.-- Scaling.sub.-- 3d ) then                                       Adj.sub.-- Max.sub.-- Alt.sub.-- 3d := Current.sub.-- Adj.sub.-- Altitude.     sub.-- 3d;                                                                     end if;                                                                        .                                                                              .                                                                              .                                                                              .                                                                              set up vertical scale from max altitude in last pass                           if ( Adj.sub.-- Max.sub.-- Alt.sub.-- 3d <= 0.0 )                              then                                                                           Cur.sub.-- vert.sub.-- scale.sub.-- 3d := 0.005;                               Max.sub.-- Adj.sub.-- Alt.sub.-- In.sub.-- Use := Units.Feet(Min.sub.--        Alt.sub.-- For.sub.-- Scaling.sub.-- 3d);                                      Max.sub.-- Baro.sub.-- Alt.sub.-- In.sub.-- Use := Units.Feet(Min.sub.--       Alt.sub.-- For.sub.-- Scaling.sub.-- 3d);                                      else                                                                           Cur.sub.-- vert.sub.-- scale.sub.-- 3d :=                                                     ( Long.sub.-- Float(Display.sub.-- Center.sub.-- Y) /                            Long.sub.-- Float(Adj.sub.-- Max.sub.-- Alt.sub.-- 3d)                       )*                                                                            Long.sub.-- Float(0.8);                                          Max.sub.-- Adj.sub.-- Alt.sub.-- In.sub.-- Use := Units.Feet(Adj.sub.--        Max.sub.-- Alt.sub.-- 3d);                                                     Max.sub.-- Baro.sub.-- Alt.sub.-- In.sub.-- Use := Units.Feet(Max.sub.--       Baro.sub.-- Alt.sub.-- 3d);                                                    end if;                                                                        THE FOLLOWING CODE FRAGMENT AND PROCEDURE SHOW THE AUTO VIEW                   FUNCTIONALITY BASED ON INBOUND COURSE OF THE MAP CENTER.                       time dependent auto rotate                                                     executed every 1/20 second                                                     Angle.sub.-- 3d.sub.-- About.sub.-- Z := norm.sub.-- angle(Angle.sub.--        3d.sub.-- About.sub.-- Z);                                                     if ( Auto.sub.-- Rotating ) then                                               if ( ( target.sub.-- auto.sub.-- angle.sub.-- delta > 0.0 ) and                ( cum.sub.-- auto.sub.-- angle.sub.-- delta >= target.sub.-- auto.sub.--       angle.sub.-- delta ) )                                                         or ( ( target.sub.-- auto.sub.-- angle.sub.-- delta <= 0.0) and                ( cum.sub.-- auto.sub.-- angle.sub.-- delta <= target.sub.-- auto.sub.--       Angle.sub.-- delta ) )                                                         then                                                                           Auto.sub.-- Rotating := False;                                                 else                                                                           Angle.sub.-- 3d.sub.-- About.sub.-- Z := Angle.sub.-- 3d.sub.-- About.sub.     -- Z + Auto.sub.-- Z.sub.-- Delta;                                             cum.sub.-- auto.sub.-- angle.sub.-- delta := cum.sub.-- auto.sub.--            angle.sub.-- delta + Auto.sub.-- Z.sub.-- Delta;                               Set.sub.-- Rot.sub.-- Angle.sub.-- Data( Rot.sub.-- X => Angle.sub.--          3d.sub.-- About.sub.-- X,                                                      Rot.sub.-- Z => Angle.sub.-- 3d.sub.-- About.sub.-- Z);                        if Graphic.sub.-- Map then                                                             Display.sub.-- Map.sub.-- Data;                                        end if;                                                                        end if;                                                                        end if;                                                                        |................................................................     ..........................................................................     .......................                                                        procedure Set.sub.-- Map.sub.-- Ctr.sub.-- In.sub.-- Crs(In.sub.-- Crs :       in Units.Long.sub.-- Radians) is                                               |                                                                     | PURPOSE - Sets the map center inbound course and deltas for         auto view.                                                                     |   3d addition.                                                      | LIMITATIONS/EXCEPTIONS - None.                                      |................................................................     ..........................................................................     .......................                                                        norm.sub.-- z.sub.-- minus.sub.-- crs                                                      : Units.Radians;                                                   new.sub.-- crs                                                                             : Units.Radians;                                                   delta.sub.-- angle                                                                         : Units.Radians;                                                   begin                                                                          new.sub.-- crs := Units.Radians(In.sub.-- Crs);                                if hold.sub.-- relative.sub.-- mode and (new.sub.-- crs /= Last.sub.--         In.sub.-- Crs)                                                                 then                                                                           if Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Is.sub.-- Set then -- not first         inbound course spec                                                                    Auto.sub.-- Rotating := True;                                                  Auto.sub.-- Z.sub.-- Target.sub.-- Value :=                                                Angle.sub.-- 3d.sub.-- About.sub.-- Z +                                        (new.sub.-- crs - Map.sub.-- Ctr.sub.-- In.sub.--                              Crs.Value);                                                        set up for 2 second move to new value                                          delta.sub.-- angle := Auto.sub.-- Z.sub.-- Target.sub.-- Value -               Angle.sub.-- 3d.sub.-- About.sub.-- Z;                                         go the shortest way around                                                     if delta.sub.-- angle > Units.Pi then                                            delta.sub.-- angle := delta.sub.-- angle - ( 2.0 * Units.Pi );               elsif delta.sub.-- angle < (0.0 - Units.Pi ) then                                delta.sub.-- angle := delta.sub.-- angle + ( 2.0 * Units.Pi );               end if;                                                                        Auto.sub.-- Z.sub.-- Delta := (delta.sub.-- angle)/40.0; -- 2 sec              @ 20 Hz                                                                        cum.sub.-- auto.sub.-- angle.sub.-- delta := 0.0;                              target.sub.-- auto.sub.-- angle.sub.-- delta := delta.sub.--                   angle;                                                                         Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Is.sub.-- Set := True;                     Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Value := new.sub.-- crs;           else -- first in course                                                                Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Value := new.sub.-- crs;                   Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Is.sub.-- Set := True;                     if auto.sub.-- angle.sub.-- mode = Profile.sub.-- View then                      Set.sub.-- Z.sub.-- Rot.sub.-- Angle.sub.-- Profile.sub.--                     Relative;                                                                    elsif auto.sub.-- angle.sub.-- mode = Shoulder.sub.-- View then                  Set.sub.-- Z.sub.-- Rot.sub.-- Angle.sub.-- Shoulder.sub.--                    View.sub.-- Relative;                                                        end if;                                                                end if;                                                                        Draw.sub.-- 3d.Set.sub.-- Rot.sub.-- Angle.sub.-- Data(                                             Rot.sub.-- X => Angle.sub.-- 3d.sub.-- About.sub.--                            X,                                                                             Rot.sub.-- Z => Angle.sub.-- 3d.sub.-- About.sub.--                            Z);                                                       end if;                                                                        Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Is.sub.-- Set := True;                     Map.sub.-- Ctr.sub.-- In.sub.-- Crs.Value := new.sub.-- crs;                   Last.sub.-- In.sub.-- Crs := new.sub.-- crs;                                   end Set.sub.-- Map.sub.-- Ctr.sub.-- In.sub.-- Crs;                            THIS PROCEDURE DRAWS DIRECTION ARROWS ON A 3D DISPLAY AVOIDING THE             PROBLEMS OF VIEWING ARROWS FROM IN FRONT AND BEHIND BY USING THE FACT          THAT                                                                           IN THOSE CASES, THE 3D LINE LENGTH WILL BE SHORT. FURTHER, A FIXED SIZE        ARROW HEAD CAN BE USED WITHOUT LOSS OF 3D EFFECT WITH THIS ALGORITHM.          |................................................................     ..........................................................................     .......................                                                        procedure Line.sub.-- 3D.sub.-- Direction.sub.-- Arrow(                                      Win  : in Windows.Window.sub.-- Type;                                          From.sub.-- x                                                                       : in Windows.Pixel.sub.-- Count.sub.-- Type;                              From.sub.-- y                                                                       : in WIndows.Pixel.sub.-- Count.sub.-- Type;                              To.sub.-- x                                                                         : in WIndows.Pixel.sub.-- Count.sub.-- Type;                              To.sub.-- y                                                                         : in WIndows.Pixel.sub.-- Count.sub.-- Type;                              center.sub.-- x                                                                     : in WIndows.Pixel.sub.-- Count.sub.-- Type;                              center.sub.-- y                                                                     : in Windows.Pixel.sub.-- Count.sub.-- Type                               ) is                                                             |                                                                     | if line length > Q then draw a direction arrow in the midpoint      of the                                                                         | line pointing to the To point.                                      |                                                                     |................................................................     ..........................................................................     .......................                                                        x.sub.-- del                                                                            : Float;                                                              y.sub.-- del                                                                            : Float;                                                              y.sub.-- over.sub.-- x                                                                  : Float;                                                              line.sub.-- len                                                                         : Float;                                                              mid.sub.-- pt.sub.-- x                                                                  : Windows.Pixel.sub.-- Count.sub.-- Type;                             mid.sub.-- pt.sub.-- y                                                                  : WIndows.Pixel.sub.-- Count.sub.-- Type;                             Rot.sub.-- Pos.sub.-- x                                                                 : Windows.Pixel.sub.-- Count.sub.-- Type;                             Rot.sub.-- Pos.sub.-- y                                                                 : Windows.Pixel.sub.-- Count.sub.-- Type;                             Pos.sub.-- x                                                                            : Windows.Pixel.sub.-- Count.sub.-- Type;                             Pos.sub.-- Y                                                                            : WIndows.Pixel.sub.-- Count.sub.-- Type;                             Sin.sub.-- Rot.sub.-- Ang                                                               : Float;                                                              Cos.sub.-- Rot.sub.-- Ang                                                               : Float;                                                              a        : Units.Radians;                                                      tsin     : float;                                                              tcos     : float;                                                              subtype Points.sub.-- Array.sub.-- 3 is Windows.Vector.sub.-- of.sub.--        Point.sub.-- Type(1..3);                                                       Arrow.sub.-- Head                                                                       : Points.sub.-- Array.sub.-- 3;                                       begin                                                                          determine line length                                                          x.sub.-- del := Float(To.sub.-- X - From.sub.-- X);                            y.sub.-- del := Float(To.sub.-- Y - From.sub.-- Y);                            line.sub.-- len := Sqrt ( x.sub.-- del*x.sub.-- Del + y.sub.-- del*y.sub.-     - del );                                                                       if ( line.sub.-- len > 50.0 ) then -- show an arrow                            sin.sub.-- Rot.sub.-- Ang := x.sub.-- del/line.sub.-- len;                     cos.sub.-- rot.sub.-- ang := -1.0 * (y.sub.-- del/line.sub.-- len);                    determine mid-point position                                                   mid.sub.-- pt.sub.-- x := From.sub.-- X + Windows.Pixel.sub.--                 Count.sub.-- Type(x.sub.-- del/2.0);                                           mid.sub.-- pt.sub.-- y := From.sub.-- Y + Windows.Pixel.sub.--                 Count.sub.-- Type(y.sub.-- del/2.0);                                             draw the direction arrow                                                       Point3                                                                                 .                                                                              . .                                                                            .  .                                                                           .......                                                                Point1                                                                             Point2                                                                   Pos.sub.-- X := -3;                                                            Pos.sub.-- Y := 0;                                                             Rot.sub.-- Pos.sub.-- X := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Cos.sub.-- Rot.sub.-- Ang) -                            (Float(Pos.sub.-- Y) * Sin.sub.-- Rot.sub.-- Ang)                              );                                                                       Rot.sub.-- Pos.sub.-- Y := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Sin.sub.-- Rot.sub.-- Ang) +                            (Float(Pos.sub.-- Y) * Cos.sub.-- Rot.sub.-- Ang)                              );                                                                       Arrow.sub.-- Head(1).X := mid.sub.-- pt.sub.-- X + Rot.sub.--                  Pos.sub.-- X + center.sub.-- x;                                                Arrow.sub.-- Head(1).Y := mid.sub.-- pt.sub.-- Y + Rot.sub.--                  Pos.sub.-- Y + center.sub.-- y;                                                Pos.sub.-- X := 3;                                                             Pos.sub.-- Y := 0;                                                             Rot.sub.-- Pos.sub.-- X := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Cos.sub.-- Rot.sub.-- Ang) -                            (Float(Pos.sub.-- Y) * Sin.sub.-- Rot.sub.-- Ang)                              );                                                                       Rot.sub.-- Pos.sub.-- Y := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Sin.sub.-- Rot.sub.-- Ang) +                            (Float(Pos.sub.-- Y) * Cos.sub.-- Rot.sub.-- Ang)                              );                                                                       Arrow.sub.-- Head(2).X := mid.sub.-- pt.sub.-- X + Rot.sub.--                  Pos.sub.-- X + center.sub.-- x;                                                Arrow.sub.-- Head(2).Y := mid.sub.-- pt.sub.-- Y + Rot.sub.--                  Pos.sub.-- Y + center.sub.-- y;                                                Pos.sub.-- X := 0;                                                             Pos.sub.-- Y := -10;                                                           Rot.sub.-- Pos.sub.-- X := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Cos.sub.-- Rot.sub.-- Ang) -                            (Float(Pox.sub.-- Y) * Sin.sub.-- Rot.sub.-- Ang)                              );                                                                       Rot.sub.-- Pos.sub.-- Y := Windows.Pixel.sub.-- Count.sub.--                   Type(                                                                                (Float(Pos.sub.-- X) * Sin.sub.-- Rot.sub.-- Ang) +                            (Float(Pos.sub.-- Y) * Cos.sub.-- Rot.sub.-- Ang)                              );                                                                       Arrow.sub.-- Head(3).X := Mid.sub.-- pt.sub.-- X + Rot.sub.--                  Pos.sub.-- X + center.sub.-- x;                                                Arrow.sub.-- Head(3).Y := mid.sub.-- pt.sub.-- Y + Rot.sub.--                  Pos.sub.-- Y + center.sub.-- y;                                                if Do.sub.-- Draw.sub.-- 3d then                                                 Fill.sub.-- Polygon (Win, GC.sub.-- Array(GREEN),                                    Arrow.sub.-- Head, Windows.CONVEX, Windows.ORIGIN);                    end if;                                                                end if;                                                                        end Line.sub.-- 3d.sub.-- Direction.sub.-- Arrow;                              THESE ROUTINES PERFORM THE BASIC TRANSFORMATIONS OF THE 3D PLAN MAP BASED      ON                                                                             THE CURRENT ROTATION ANGLES:                                                   XFORM.sub.-- SCREEN.sub.-- UNITS                                                                TRANSFORMS POINTS THAT ARE IN SCREEN UNITS                    XFORM.sub.-- LAT.sub.-- LONG                                                                    TRANSFORMS POINTS THAT ARE IN LATITUDE,LONGITUDE              XFORM.sub.-- FORWARD.sub.-- FACING.sub.-- SCREEN.sub.-- UNITS                                   DOES A TRANSFORMATION THAT CORRECTLY POSITIONS                                 A POINT SUCH THAT AN OBJECT COMPOSED OF SUCH                                   POINTS FACES FORWARD ON THE SCREEN FOR ANY                                     ROTATION ANGLES (SUCH AS TRIANGLES USED WITH                                   ALTITUDE LINES)                                               |................................................................     ..........................................................................     .......................                                                        procedure xform.sub.-- screen.sub.-- units (                                   x.sub.-- in : in Windows.Pixel.sub.-- Count.sub.-- Type;                       y.sub.-- in : in Windows.Pixel.sub.-- Count.sub.-- Type;                       rot.sub.-- z.sub.-- in : in Units.Radians;                                     rot.sub.-- x.sub.-- in : in Units.Radians;                                     display.sub.-- center.sub.-- x.sub.-- in : in Windows.Pixel.sub.--             Count.sub.-- Type;                                                             display.sub.-- center.sub.-- y.sub.-- in : in Windows.Pixel.sub.--             Count.sub.-- Type;                                                             alt.sub.-- in : in float                                                                             := Current.sub.-- Altitude.sub.-- 3d; -- feet            vertical.sub.-- scale.sub.-- factor.sub.-- in : in long.sub.-- float                                 := Cur.sub.-- Vert.sub.-- Scale.sub.-- 3d;               x.sub.-- out : out Windows.Pixel.sub.-- Count.sub.-- Type;                     y.sub.-- out : out Windows.Pixel.sub.-- Count.sub.-- Type) is                  |                                                                     | This procedure does the transformation for the 3D Plan Map.         |                                                                     | NOTES:                                                              |                                                                     FOR x AND y IN SCREEN UNITS RELATIVE TO THE ORIGIN, NOT SCREEN CENTER          |                                                                     (So, subtract screen center coordinates if relative to them)                   |................................................................     ..........................................................................     .......................                                                        x, y, rot.sub.-- z, rot.sub.-- x, display.sub.-- center.sub.-- x,              display.sub.-- center.sub.-- y : float;                                        alt, vertical.sub.-- scale.sub.-- factor : float;                              xp, yp : float;                                                                begin                                                                          x := float(x.sub.-- in);                                                       y := float(y.sub.-- in);                                                       rot.sub.-- z := float(rot.sub.-- z.sub.-- in);                                 rot.sub.-- x := float(rot.sub.-- x.sub.-- in);                                 display.sub.-- center.sub.-- x := float(display.sub.-- center.sub.--           x.sub.-- in);                                                                  display.sub.-- center.sub.-- y := float(display.sub.-- center.sub.--           y.sub.-- in);                                                                  alt := float(alt.sub.-- in);                                                   vertical.sub.-- scale.sub.-- factor := float(vertical.sub.-- scale.sub.--      factor.sub.-- in);                                                             xp :=    x * Cos(rot.sub.-- z) +                                                        y * Sin(rot.sub.-- z) +                                                        display.sub.-- center.sub.-- x;                                       yp :=    x * (-Sin(rot.sub.-- z)) * Cos(rot.sub.-- x) +                                 y * Cos(rot.sub.-- z) * Cos(rot.sub.-- x) +                                    alt * vertical.sub.-- scale.sub.-- factor * (-Sin(rot.sub.-- x))               +                                                                              display.sub.-- center.sub.-- y;                                       x.sub.-- out := Windows.Pixel.sub.-- Count.sub.-- Type( xp );                  y.sub.-- out := Windows.Pixel.sub.-- Count.sub.-- Type( yp );                  end xform.sub.-- screen.sub.-- units;                                          |................................................................     ..........................................................................     .......................                                                        procedure xform.sub.-- lat.sub.-- long (                                       lat.sub.-- in     : in long.sub.-- float;                                      long.sub.-- in    : in long.sub.-- float;                                      ref.sub.-- lat.sub.-- in                                                                         : in long.sub.-- float;                                      ref.sub.-- long.sub.-- in                                                                        : in long.sub.-- float;                                      map.sub.-- scale.sub.-- factor.sub.-- in                                                         : float;                                                     rot.sub.-- z.sub.-- in                                                                           : in Units.Radians;                                          rot.sub.-- x.sub.-- in                                                                           : in Units.Radians;                                          display.sub.-- center.sub.-- x.sub.-- in                                                         : in Windows.Pixel.sub.-- Count.sub.-- Type;                 display.sub.-- center.sub.-- y.sub.-- in                                                         : in Windows.Pixel.sub.-- Count.sub.-- Type;                 alt.sub.-- in     : in float := Current.sub.-- Altitude.sub.-- 3d; --                            feet                                                         vertical.sub.-- scale.sub.-- factor.sub.-- in                                                    : in long.sub.-- float := Cur.sub.-- Vert.sub.--                               Scale.sub.-- 3d;                                             x.sub.-- out      : out Windows.Pixel.sub.-- Count.sub.-- Type;                y.sub.-- out      : out Windows.Pixel.sub.-- Count.sub.-- Type) is             |                                                                     |                                                                     This routine performs the transformation for the 3D Plan Map                   | including the tangent plane projection of latitude and              longitude.                                                                     |................................................................     ..........................................................................     .......................                                                        map.sub.-- scale.sub.-- factor : long.sub.-- float;                            x, y : long.sub.-- float;                                                      xp, yp : Windows.Pixel.sub.-- Count.sub.-- Type;                               EARTH.sub.-- RADIUS : long.sub.-- float := 3444.3295;                          begin                                                                          map.sub.-- scale.sub.-- factor := long.sub.-- float( map.sub.-- scale.sub.     -- factor.sub.-- in );                                                         x := EARTH.sub.-- RADIUS * Cos(lat.sub.-- in) * Sin(long.sub.-- in -           ref.sub.-- long.sub.-- in);                                                    y := (-EARTH.sub.-- RADIUS) *                                                              ( Sin(lat.sub.-- in) * Cos(ref.sub.-- lat.sub.-- in) -                           Cos(lat.sub.-- in) * Sin(ref.sub.-- lat.sub.-- in) *                           Cos(long.sub.-- in - ref.sub.-- long.sub.-- in)                              );                                                                 xp := Windows.Pixel.sub.-- Count.sub.-- Type( x * map.sub.-- scale.sub.--      factor ) ;                                                                     yp := Windows.Pixel.sub.-- Count.sub.-- Type( y * map.sub.-- scale.sub.--      factor ) ;                                                                     x and y are now in screen units relative to the window origin                    so do same as previous procedure                                             xform.sub.-- screen.sub.-- units (                                                     x.sub.-- in => xp,                                                             : inWindows.Pixel.sub.-- Count                                                 y.sub.-- in => yp ,                                                            : inWindows.Pixel.sub.-- Count                                                 rot.sub.-- z.sub.-- in => rot.sub.-- z.sub.-- in,                              : in Units.Radians;                                                            rot.sub.-- x.sub.-- in => rot.sub.-- x.sub.-- in,                              : in Units.Radians;                                                            display.sub.-- center.sub.-- x.sub.-- in => display.sub.--                     center.sub.-- x.sub.-- in,                                                     : inWindows.Pixel.sub.-- Count                                                 display.sub.-- center.sub.-- y.sub.-- in => display.sub.--                     center.sub.-- y.sub.-- in,                                                     : inWindows.Pixel.sub.-- Count                                                 alt.sub.-- in => alt.sub.-- in,                                                : in float Feet;                                                               vertical.sub.-- scale.sub.-- factor.sub.-- in => vertical.sub.--               scale.sub.-- factor.sub.-- in, --: in float;                                   x.sub.-- out => x.sub.-- out,                                                  : outWindows.Pixel.sub.-- Count                                                y.sub.-- out => y.sub.-- out                                                   : outWindows.Pixel.sub.-- Count                                                );                                                                     end xform.sub.-- lat.sub.-- long;                                              |................................................................     ..........................................................................     .......................                                                        procedure xform.sub.-- forward.sub.-- facing.sub.-- screen.sub.-- units(       symbol.sub.-- center.sub.-- x.sub.-- in : in Windows.Pixel.sub.--              Count.sub.-- Type;                                                             symbol.sub.-- center.sub.-- y.sub.-- in : in Windows.Pixel.sub.--              Count.sub.-- Type;                                                             x.sub.-- in : in Windows.Pixel.sub.-- Count.sub.-- Type;                       y.sub.-- in : in Windows.Pixel.sub.-- Count.sub.-- Type;                       rot.sub.-- z.sub.-- in : in Units.Radians;                                     rot.sub.-- x.sub.-- in : in Units.Radians;                                     display.sub.-- center.sub.-- x.sub.-- in : in Windows.Pixel.sub.--             Count.sub.-- Type;                                                             display.sub.-- center.sub.-- y.sub.-- in : in Windows.Pixel.sub.--             Count.sub.-- Type;                                                             alt.sub.-- in : in float                                                                               := Current.sub.-- Altitude.sub.-- 3d; -- feet          vertical.sub.-- scale.sub.-- factor.sub.-- in : in long.sub.-- float                                   := Cur.sub.-- Vert.sub.-- Scale.sub.-- 3d;             x.sub.-- out : out Windows.Pixel.sub.-- Count.sub.-- Type;                     y.sub.-- out : out Windows.Pixel.sub.-- Count.sub.-- Type) is                  |                                                                     | This procedure performs the transformation for graphic items        which                                                                          | always are to face forward on the display.                          |................................................................     ..........................................................................     .......................                                                        x, y, rot.sub.-- z, rot.sub.-- x, display.sub.-- center.sub.-- x,              display.sub.-- center.sub.-- y : float;                                        alt, vertical.sub.-- scale.sub.-- factor, symbol.sub.-- center.sub.-- x,       symbol.sub.-- center.sub.-- y : float;                                         x.sub.-- pre.sub.-- rot, y.sub.-- pre.sub.-- rot : float;                      x.sub.-- pre.sub.-- rot.sub.-- su, y.sub.-- pre.sub.-- rot.sub.-- su :         Windows.Pixel.sub.-- Count.sub.-- Type;                                        xp, yp : float;                                                                begin                                                                          x := float(x.sub.-- in);                                                       y := float(y.sub.-- in);                                                       rot.sub.-- z := float(rot.sub.-- z.sub.-- in);                                 rot.sub.-- x := float(rot.sub.-- x.sub.-- in);                                 display.sub.-- center.sub.-- x := float(display.sub.-- center.sub.--           x.sub.-- in);                                                                  display.sub.-- center.sub.-- y := float(display.sub.-- center.sub.--           y.sub.-- in);                                                                  symbol.sub.-- center.sub.-- x := float( symbol.sub.-- center.sub.--            x.sub.-- in );                                                                 symbol.sub.-- center.sub.-- y := float( symbol.sub.-- center.sub.--            y.sub.-- in );                                                                 pre-rotate about origin in opposite direction of z rotation                    x.sub.-- pre.sub.-- rot :=                                                               (x - symbol.sub.-- center.sub.-- x + display.sub.-- center.sub.-               - x) * Cos(rot.sub.-- z) +                                                     (y - symbol.sub.-- center.sub.-- y + display.sub.-- center.sub.-               - y) * (-Sin(rot.sub.-- z));                                         y.sub.-- pre.sub.-- rot :=                                                               (x - symbol.sub.-- center.sub.-- x + display.sub.-- center.sub.-               - x) * Sin(rot.sub.-- z) +                                                     (y - symbol.sub.-- center.sub.-- y + display.sub.-- center.sub.-               - y) * Cos(rot.sub.-- z);                                            move symbol back                                                               x.sub.-- pre.sub.-- rot := x.sub.-- pre.sub.-- rot + symbol.sub.--             center.sub.-- x - display.sub.-- center.sub.-- x;                              y.sub.-- pre.sub.-- rot := y.sub.-- pre.sub.-- rot + symbol.sub.--             center.sub.-- y - display.sub.-- center.sub.-- y;                              x.sub.-- pre.sub.-- rot.sub.-- su := Windows.Pixel.sub.-- Count.sub.--         Type( x.sub.-- pre.sub.-- rot );                                               y.sub.-- pre.sub.-- rot.sub.-- su := Windows.Pixel.sub.-- Count.sub.--         Type( y.sub.-- pre.sub.-- rot );                                               transform as usual                                                             xform.sub.-- screen.sub.-- units (                                                     x.sub.-- in => x.sub.-- pre.sub.-- rot.sub.-- su,                              : inWindows.Pixel.sub.-- Count                                                 y.sub.-- in => y.sub.-- pre.sub.-- rot.sub.-- su ,                             : inWindows.Pixel.sub.-- Count                                                 rot.sub.-- z.sub.-- in => rot.sub.-- z.sub.-- in,                              : in Units.Radians;                                                            rot.sub.-- x.sub.-- in => rot.sub.-- x.sub.-- in,                              : in Units.Radians;                                                            display.sub.-- center.sub.-- x.sub.-- in => display.sub.--                     center.sub.-- x.sub.-- in,                                                     : inWindows.Pixel.sub.-- Count                                                 display.sub.-- center.sub.-- y.sub.-- in => display.sub.--                     center.sub.-- y.sub.-- in,                                                     : inWindows.Pixel.sub.-- Count                                                 alt.sub.-- in => alt.sub.-- in,                                                : in float Feet;                                                               vertical.sub.-- scale.sub.-- factor.sub.-- in => vertical.sub.--               scale.sub.-- factor.sub.-- in, --: in float;                                   x.sub.-- out => x.sub.-- out,                                                  : outWindows.Pixel.sub.-- Count                                                y.sub.-- out => y.sub.-- out                                                   : outWindows.Pixel.sub.-- Count                                                );                                                                     end xform.sub.-- forward.sub.-- facing.sub.-- screen.sub.-- units;             __________________________________________________________________________ 

We claim:
 1. A flight management system for an aircraft, comprising:means for inputting flight plan information; means for calculating a flight plan; means for generating a graphical representation of the flight plan wherein said graphical representation is three-dimensional and is automatically adjusted as a flight progresses while simultaneously maintaining a preset viewing direction relative to the aircraft.
 2. A flight management system for an aircraft, comprising:a flight management system computer; a control display unit operably coupled to the flight management system computer; a display unit operably coupled to the flight management system computer for generating and displaying a graphical representation of a flight plan wherein said graphical representation is three-dimensional and is automatically adjusted as a flight progresses while simultaneously maintaining a preset viewing direction relative to the aircraft.
 3. A method for displaying flight management information comprising a graphical representation of a flight plan of an aircraft, comprising the steps of:providing flight plan information; calculating a flight path; displaying a three-dimensional representation of air space, said three-dimensional representation of air space oriented according to a preset viewing direction relative to the aircraft; displaying said flight path within said three-dimensional display of air space; and automatically adjusting the display as a flight progresses so as to maintain said preset viewing direction relative to the aircraft.
 4. A flight management system, comprising:a flight management system computer; a control display unit operably coupled to the flight management system computer; a display unit for displaying flight plan information within a viewing area on a video display, wherein the resolution of a vertical dimension on the display depicting altitude is automatically adjusted according to flight plan altitude details to be displayed within said viewing area, comprising:means for reading said flight plan information; means for generating and displaying a pictorial representation of a flight plan, said pictorial representation comprising a flight path displayed relative to a vertical scale depicting altitude; and means for automatically adjusting the resolution of the vertical scale so that the resolution of the vertical scale varies inversely with the maximum altitude of the flight path to be displayed within the viewing area of the display.
 5. A flight management system of claim 4, wherein the resolution of the vertical scale is adjusted to be as great as possible and still shows the highest point of the flight path to be displayed within the viewing area of the display.
 6. A flight management system of claim 4, wherein said pictorial representation comprising said flight path is further displayed relative to a pictorial representation of three-dimensional air space.
 7. A flight management system of claim 4, wherein said pictorial representation comprising said flight path is further displayed relative to a horizontal scale depicting horizontal distance relative to a reference axis.
 8. In a flight management system, a display system for displaying flight plan information within a viewing area on a video display, wherein the resolution of the vertical scale depicting altitude is dynamically adjusted according to flight plan altitude details to be displayed within said viewing area, comprising:means for reading said flight plan information; means for generating and displaying a pictorial representation of a flight plan, said pictorial representation comprising a flight path displayed relative to a vertical scale depicting altitude; and means for automatically adjusting the resolution of the vertical scale so that the resolution of the vertical scale varies inversely with the maximum altitude of the flight path to be displayed within the viewing area of the display.
 9. A display system of claim 8, wherein the resolution of the vertical scale is adjusted to be as great as possible and still shows the highest point of the flight path to be displayed within the viewing area of the display.
 10. A display system of claim 8, wherein said pictorial representation comprising said flight path is further displayed relative to a pictorial representation of three-dimensional air space.
 11. A display system of claim 8, wherein said pictorial representation comprising said flight path is further displayed relative to a horizontal scale depicting horizontal distance relative to a reference axis.
 12. A method for displaying flight management information comprising a graphical representation of a flight plan of an aircraft, comprising the steps of:providing flight plan information; calculating a flight path; displaying a pictorial representation of a flight plan, said pictorial representation comprising a flight path displayed in relation to a vertical scale depicting altitude; and automatically adjusting the resolution of the vertical scale so that the resolution of the vertical scale varies inversely with the maximum altitude of the flight path to be displayed within the viewing area of the display.
 13. A method of claim 12, wherein the resolution of the vertical scale is adjusted to be as great as possible and still shows the highest point of the flight path to be displayed within the viewing area of the display.
 14. A method of claim 12, wherein said pictorial representation comprising said flight path is further displayed relative to a pictorial representation of three-dimensional air space.
 15. A method of claim 12, wherein said pictorial representation comprising said flight path is further displayed relative to a horizontal scale depicting horizontal distance relative to a reference axis. 